草庐IT

sql-server - XML 到 SQL 的映射

全部标签

ruby - Ruby 有像栈、队列、链表、映射或集合这样的容器吗?

我在网上查了几个Ruby教程,他们似乎什么都用数组。那么如何在Ruby中实现以下数据结构呢?堆栈队列链表map组 最佳答案 (从评论中移出)好吧,通过限制堆栈或队列方法(push、pop、shift、unshift),数组可以是堆栈或队列。使用push/pop提供LIFO(后进先出)行为(堆栈),而使用push/shift或unshift/pop提供FIFO行为(队列)。map是hashes,和一个Set类已经存在。您可以使用类实现链表,但数组将使用标准数组方法提供类似于链表的行为。 关

sql - ActiveRecord Arel OR 条件

如何使用逻辑OR而不是AND来组合2个不同的条件?注意:2个条件是作为rails范围生成的,不能轻易地直接更改为where("xory")之类的内容。简单的例子:admins=User.where(:kind=>:admin)authors=User.where(:kind=>:author)很容易应用AND条件(对于这种特殊情况是没有意义的):(admins.mergeauthors).to_sql#=>select...from...wherekind='admin'ANDkind='author'但是您如何生成具有2个不同Arel关系的以下查询?#=>select...from.

ruby-on-rails - '需要': cannot load such file -- 'nokogiri\nokogiri' (LoadError) when running `rails server`

我正在使用DevKit在Windows8.1上运行全新安装的Ruby2.2.1。安装后我运行:geminstallrailsrailsnewtestappcdtestapprailsserver保留其他所有默认值。进程在最后一行失败,我没有运行服务器,而是收到错误消息in'require':cannotloadsuchfile--'nokogiri\nokogiri'(LoadError)每次都会发生这种情况,我环顾四周并尝试了我发现的所有方法来修复它,但到目前为止没有任何效果。这里的问题是什么?如何让一个简单的测试Rails应用程序正常工作? 最佳答案

ruby - 通过 Nginx 的 EventSource/Server-Sent 事件

在服务器端使用带有streamblock的Sinatra。get'/stream',:provides=>'text/event-stream'dostream:keep_opendo|out|connections在客户端:vares=newEventSource('/stream');es.onmessage=function(e){$('#chat').append(e.data+"\n")};当我通过http://localhost:9292/直接使用应用程序时,一切正常。连接是持久的,所有消息都传递给所有客户端。但是,当它通过Nginx时,http://chat.dev,连接

ruby - 使用局域网中的移动设备连接到本地构建的 Jekyll Server

在一台机器上使用jekyllserve后,一个WEBrick服务器就设置好了,站点可以从这台特定PC上的localhost:4000访问。但是,我想知道如何从局域网中的其他机器访问这个网络服务器,特别是对于移动设备?在将代码推送到Github之前,我尝试在移动设备上测试jekyll站点。 最佳答案 当您在命令行上调用Jekyll时,尝试jekyllserve--host=0.0.0.0。这将使Jekyll的HTTP服务器绑定(bind)到所有可用的IP,而不仅仅是绑定(bind)到localhost。您还可以使用host:0.0.0

ruby-on-rails - Rails 将哈希数组映射到单个哈希

我有一个像这样的哈希数组:[{"testPARAM1"=>"testVAL1"},{"testPARAM2"=>"testVAL2"}]我正在尝试将其映射到单个散列,如下所示:{"testPARAM2"=>"testVAL2","testPARAM1"=>"testVAL1"}我是用实现的par={}mitem["params"].each{|h|h.each{|k,v|par[k]=v}}但我想知道是否有可能以更惯用的方式来做到这一点(最好不使用局部变量)。我该怎么做? 最佳答案 您可以组合Enumerable#reduce和Ha

ruby-on-rails - 如何在 RSpec 测试中打开 ActiveRecord 的 SQL 调试日志记录?

我对我的模型进行了一些RSpec测试,我想像在Rails服务器模式中看到的那样打开SQLActiveRecord日志记录。如何做到这一点?我开始我的测试RAILS_ENV=testbundleexecrspecmy/test_spec.rb谢谢 最佳答案 您可以尝试在某处的测试中将ActiveRecord记录器设置为标准输出。如果您正在使用rspec,也许在spechelper中?ActiveRecord::Base.logger=Logger.new(STDOUT) 关于ruby-on

sql - Rails 4 LIKE 查询 - ActiveRecord 添加引号

我正在尝试像这样做一个类似的查询defself.search(search,page=1)paginate:per_page=>5,:page=>page,:conditions=>["nameLIKE'%?%'ORpostal_codelike'%?%'",search,search],order=>'name'end但是当它运行时,某些东西会添加引号,导致sql语句像这样出现SELECTCOUNT(*)FROM"schools"WHERE(nameLIKE'%'havard'%'ORpostal_codelike'%'havard'%')):所以你可以看到我的问题。我正在使用Rai

ruby - 如何在 Ruby 中映射和删除 nil 值

我有一个map,它可以更改值或将其设置为nil。然后我想从列表中删除nil条目。该列表不需要保留。这是我目前拥有的:#Asimpleexamplefunction,whichreturnsavalueornildeftransform(n)rand>0.5?n*10:nil}enditems.map!{|x|transform(x)}#[1,2,3,4,5]=>[10,nil,30,40,nil]items.reject!{|x|x.nil?}#[10,nil,30,40,nil]=>[10,30,40]我知道我可以像这样做一个循环并有条件地收集到另一个数组中:new_items=[]

ruby - 如何在 Ruby 中使用索引进行映射/收集?

什么是最简单的转换方式[x1,x2,x3,...,xN]到[[x1,2],[x2,3],[x3,4],...,[xN,N+1]] 最佳答案 如果您使用的是ruby​​1.8.7或1.9,您可以使用迭代器方法,如each_with_index,在没有block的情况下调用时,返回一个Enumerator对象,您可以调用Enumerable方法,例如map。所以你可以这样做:arr.each_with_index.map{|x,i|[x,i+2]}在1.8.6中你可以:require'enumerator'arr.enum_for(:e